import { getToken, setToken, removeToken } from '@/utils/auth'
import { loginAPI } from '@/api'

const getDefaultState = () => {
  return {
    token: getToken()
  }
}
const state = getDefaultState()

const mutations = {
  RESET_STATE: (state) => {
    Object.assign(state, getDefaultState())
    removeToken()
  },
  SET_TOKEN(state, payload) {
    state.token = payload
    setToken(payload)
  }
}

const actions = {
  // 登录逻辑-封装
//  async loginActions({ commit }, value) {
//   try {
//     const res = await loginAPI(value)
//     // 我们只需要token, 保存到上面的vuex中
//     commit('SET_TOKEN', res.data)
//     // 逻辑页面还在接收数组, 外面写成功/失败的逻辑, 所以这里要把数组返回出去
//     // return到actions调用的地方(login/index.vue)
//     return res
//   } catch (err) {
//     return Promise.reject(err)
//   }
// }
  async loginActions({ commit }, payload) {
    try {
      const res = await loginAPI(payload)
      commit('SET_TOKEN', res.data)
      return res
    } catch (error) {
      return Promise.reject(error)
    }
  }
}

export default {
  namespaced: true,
  state,
  mutations,
  actions
}
